草庐IT

string - Golang 将字符串拆分并解析为不同的类型

全部标签

ruby - Vpim::Vcard - 解析 vcard 2.1

我的代码必须解析Vcard2.1格式。我正在使用vpim(没有其他库)当我运行Vpim::Vcard.decode(data)时出现错误:undefinedmethod`each'for#堆栈跟踪:NoMethodError(undefinedmethod`each'for#):vpim(0.695)lib/vpim/rfc2425.rb:82:in`unfold'vpim(0.695)lib/vpim/rfc2425.rb:308:in`decode'vpim(0.695)lib/vpim/vcard.rb:692:in`decode'app/models/event.rb:71:i

ruby - 检查字符串变量是否在一组字符串中

哪个更好:x=='abc'||x=='def'||x=='ghi'%w(abcdefghi).include?xx=~/abc|def|ghi/? 最佳答案 哪个更好?这个问题不容易回答,因为他们做的事情不尽相同。x=='abc'||x=='def'||x=='ghi'%w(abcdefghi).include?x比较x与固定字符串是否相等。x必须是这些值之一。在这两者之间,我倾向于选择第二个,因为它更容易维护。想象一下,如果您必须与20、50或100个字符串进行比较会是什么样子。第三个测试:x~=/abc|def|ghi/匹配子串

ruby-on-rails - ruby 1.8 和 1.9 之间的字符串长度差异

我有一个运行在ruby​​1.8.7上的网站。我对传入的帖子进行了验证,检查以确保我们最多允许12000个字符。在对帖子进行验证之前,空格被计为字符,制表符和回车符被去除。这是经过验证的帖子http://pastie.org/5047582在ruby​​1.9中,字符串长度显示为11909,这是正确的。但是当我检查ruby​​1.8.7的长度时,结果是12044。我使用codepad.org运行这个ruby​​代码,它给了我http://codepad.org/OxgSuKGZ(输出长度为12044,这是错误的)但是当我在codeacademy.org的控制台中运行相同的代码时,字符串

ruby - rvm 中每个 ruby​​ 版本的不同 ruby​​gem 版本

我通过rvm安装了ruby​​1.8.7和1.9.3。对于每个ruby​​版本,我想:将gem1.3.7用于ruby​​1.8.7将gem1.8.x用于ruby​​1.9.3如何在rvm中设置以上内容? 最佳答案 $rvmuse1.8.7$rvmrubygems1.3.7$rvmuse1.9.3$rvmrubygemslatest-1.8$gem-v1.8.24$rvmuse1.8.7$gem-v1.3.7 关于ruby-rvm中每个ruby​​版本的不同ruby​​gem版本,我们在S

ruby-on-rails - 带分号的字符串在 RubyMine 中产生 "unterminated string meets end of file"

在RubyMine调试器中,只需在watch中输入:';'或";"我收到错误:"unterminatedstringmeetsendoffile"这是为什么?据我所知,它不会发生在Rails控制台中,并且与RubyMine没有任何关系。 最佳答案 这是Ruby调试器与Ruby解释器具有不同解析规则的结果。事实上,从irb或ruby命令调用的常规Ruby调试器表现出相同的行为。然而,解决方法很简单:要创建一个由单个分号组成的字符串文字,只需使用反斜杠将其转义即可:$irb>require'debugger'=>true>debugge

ruby - 为什么 truth && "string"返回 "string"

假设我有一个类似的东西true&&true#=>true这是有道理的,所以我尝试这样的事情:true&&"dsfdsf"#=>"dsfdsf"这让我很惊讶,因为很多时候我会做类似ifsomething&&something的事情,我一直认为那是评估为true并且会返回true。进一步的实验做这样的事情:jruby-1.7.3:009>"ad"&&"dsf"=>"dsf"jruby-1.7.3:010>"ad"&&"sdfd"&&nil=>niljruby-1.7.3:011>"ad"&&nil&&"sdf"=>nil使Ruby看起来要么返回最后一个值(如果全部为true),要么返回它找

ruby - 为什么这两个不同的正则表达式根据下划线的位置在 Ruby 中返回不同的结果

我有以下内容:.[11]pry(main)>"abBN123-4.56".scan(/BN([0-9_\.-]+)/)=>[["123-4.56"]][12]pry(main)>"abBN123-4.56".scan(/BN([0-9\.-_]+)/)=>[["123"]]我不确定为什么第二个末尾带有下划线的行为与第一个行为不同。RegEx解析器如何解释它以使其不同? 最佳答案 这是因为您将连字符(-)放在了字符类的中间而没有被转义。在字符类[]中,您可以放置​​一个连字符(-)作为first或last性格。如果您将连字符放在其他任

ruby-on-rails - 在 Rails 中,如何使用字符串数组实现 HTML 选择菜单?

我有一个FinancialDocument#document_type模型属性。我想让用户从由字符串数组填充的HTML选择菜单中选择文档类型...doctypes=['Invoice','Packingslip','Other']对于每个选项,显示的标签和返回的值都是相同的。我查看了select和collection_select助手,但它们似乎适合选择子模型,而不仅仅是一个String值。我找不到如何让它们达到我的目的。这是我正在尝试的方法(我使用的是Haml,而不是Erb)...form_for(@financial_document)do|f|-doctypes=['Invoic

ruby - 将转义的 unicode 字符串转换为 ruby​​ 1.8 中的字符

我必须阅读一些包含以下内容的文本文件:\u201CGushingCross的小贩夫人\u201D在ruby​​1.9终端中,当我创建一个包含以下内容的字符串时:ruby-1.9.1-p378>"\u2714\u2714mygreatstring\u2714\u2714"=>"✔✔mygreatstring✔✔"在ruby​​1.8中,我没有将unicode代码转换为它们的字符:ree-1.8.7-2010.01>"\u2714\u2714mygreatstring\u2714\u2714"=>"u2714u2714mygreatstringu2714u2714"有什么简单的方法可以在R

ruby - 一次读取一个 Ruby 字符串(用于自动换行)

我知道这个问题很基础。我可以使用以下方法获取用户输入的字符串和整数:str=gets()num=gets().to_i但是我想逐个字符地从字符串(比如在我的例子中长度超过一行)中读取,并计算字符串中遇到的每个字符从第一个到最后一个的字符数。我知道这可以通过以下方式实现:str.length我想在Ruby中尝试实现自动换行时以字符方式计算它,其中在行宽内(这将是用户定义的数字输入)我只想打印那些没有继续到下一行的词,即我不想将一个连续的词分成两行。这样的话应该换行。谢谢你的时间..!! 最佳答案 getc将一次读入一个字符:char=